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Abstract 

The minimum number of NOT gates in a Boolean circuit computing a Boolean 
function is called the inversion complexity of the function. In 1957, A. A. Markov deter¬ 
mined the inversion complexity of every Boolean function and proved that [log 2 (d(/)+l)] 
NOT gates are necessary and sufficient to compute any Boolean function / (where d(f) 
is maximum number of value changes from 1 to 0 over all increasing chains of tuples 
of variables values). In this paper we consider Boolean circuits over an arbitrary basis 
that consists of all monotone functions (with zero weight) and finite nonempty set of 
non-monotone functions (with unit weight). It is shown that the minimal sufficient 
for a realization of the Boolean function / number of non-monotone gates is equal to 
|"log 2 (d(/) + 1)] — 0(1). Similar extends for another classical result of A. A. Markov 
for the inversion complexity of system of Boolean functions has been obtained. 

Keywords: Boolean function complexity, circuit complexity, Boolean circuit com¬ 
plexity, inversion complexity, Markov’s theorem. 

We denote the set {0,1} by E 2 . A set of pairwise different tuples 

Oil = Mil, • • • , Clin), Oil = (Cl21, ■ • • , «2n), • • • , OL r — (a r 1 , . . . , CX rn ) 

from the set Elf such that 

Oi-ij A Cp-{-i } j , 1 1, • • • , 'O 1, 3 1, . . . , Tl 

is called increasing chain (or chain). The tuples di and b r are called initial and terminal 
tuples of the chain respectively. 

Let f(x i,, x n ) be a Boolean function. An ordered pair of tuples a = (ay, ..., a n ) and 
/3 = (Pi,..., f3 n ), a, f3 G Ef such that 

1) aj < fo, j = l,...,n; 

2) /(d) > f(0) 

is called jump. Lef F = {fi(x i,..., x n ),..., / m (ar,..., x n )} be a set of Boolean functions. 
A pair of tuples is called jump for the system F if there exists function / e F such that the 
pair is the jump for the function /. 
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Let C be a chain of the form 

Oi 1, 0^2 5 • • • ,Oi r . 

The number of jumps for the system F of the form (cq, a i+ 1 ) is called the decrease dc{F ) of 
the system F along the chain C. 

The decrease d(F) of system F is the maximum of dc{F) over all chains C. 

We will investigate a realization of Boolean functions by circuits (or Boolean circuits, 
or logic circuit, or circuit of functional elements, or combinational machine — necessary 
definitions may be found in [ 1.2 j ) over basis B of the form 

B = M U {wi,... ,oj p }, Ui G P 2 \ M, i = 1,... ,p, (*) 

and we assume that the weight of the functions from M equals zero and weight of the 
functions uii,... ,uj p equals 1. 

The complexity of circuit S (function /, function system F respectively) over basis B of 
the form (*) is called the inversion complexity over basis B and denoted by Ib{S) (/*(/), 
Ib(F ) respectively). 

Complete description of the inversion complexity of Boolean functions and systems of 
Boolean functions over B 0 = M Li {x} is given by A. A. Markov in j3j|4] (similar problems 
are also considered in [5-16]): for any Boolean functions systems F the equality 

= rio g2 (4f) + i)i 

holds. 

Since we can obtain negation (NOT gate) from any non-monotone function by substitu¬ 
tion of constants, Markov’s theorem implies the upper bound of the inversion complexity for 
arbitrary system of function over any basis B of the form (*): 

Ib(F)< riog 2 (d(F) + 1)1 . 

If B is an arbitrary basis such that for any i, 1 < i < p, the equation d{uf) = 1 holds 
then equality for inverion complexity from Markov’s theorem holds (proof of lower bound is 
similar to one in urn- 

If a basis contains at least one function Uj such that d(uj) > 1, then equality does not 
hold. On the one hand, Ib( ojj) = 1, on the other hand, inequality [log 2 (d(o;j) + 1)] >2 
holds. Moreover, the inversion complexity of F depends not only on d(F) in that case. Let 
us consider basis B 2 = M U {x © y © z © 1} as an example. Let F\ = {x © y © z © 1} and 
Fo = {x, y}. Then 

d(F 1 ) = d(F 2 ) = 2, Ib 2 (F i) = 1, Ib 2 {F 2 ) = 2. 

To prove the last equality it is enough to note that for any f(x,y ) G P 2 inequality d(f) < 1 
holds. 

The aim of this paper is to prove that despite of the fact mentioned above estimation 
of inversion complexity is almost the same for arbitrary basis B of the form (*) (even if 
d(B) > 1). Let us give exact formulation of the result. 

Theorem. For any complete basis B of the form (*) there exists constant c{B) such that 
for any system F of Boolean functions the following inequalities hold : 

(log 2 (d(F) + 1)] - c(B) < I b (F) < flog 2 (d(F) + 1)] . 


We have already mentioned that the upper bound follows from Markov’s theorem and 
the fact that negation can be obtained from any non-monotone function by substitution of 
constants. 

Let us prove lower bound for arbitrary basis B = M U {aq,..., w p }, where G B 2 \M 
(i — 1,.. .,p). Let r(B) = max{d(wi),... ,d(co p )}. 

Lemma 1. Let F C P 2 . Then 

d{F ) < (2 r(B) + 1) (2 /s(f) - l) . 

Proof. Let F = {fi(xi ,..., x n ),..., f m (x l, • • •, x n )} C P 2 . The proof is by induction 
over Ib(F). 

If Ib(F) = 0 then F C M. Hence, d(F) = 0. 

Assume the assertion is valid for any G C P 2 such that Ib(G) < I b (F) - 1. 

Let us consider a circuit S with n inputs X\,... ,x n that realize system F and contains 
exactly Ib{F) vertices corresponding to functions from {cci,... ,u p }. Let us select the first 
such vertex (according to any correct numeration) and let us denote corresponding gate by 
E. Denote by h(x i,... ,x n ) function that is obtained at the output of E. Denote by S' a 
circuit that is obtained from the circuit S by replacement the gate E with one more input 
with variable y. The circuit S' realize system G = {g ±,..., g m } with the following properties: 

fi(x i,.. ■, x n ) = gt (h(x i,..., x n ), xi,...,x n ), i = 1,..., m. 

Moreover, Ib(G) < Ib(F) — 1. 

Consider a chain C 

C = (cti, Q! 2 ,.. ■, 6t r ) 

such that d(F) = dc{F). 

Let us consider the sequence C' of (n + l)-tuples: 

(h(a i),bi),..., (h(a r ),a r ). 

The sequence C' is not a chain. Since d(h) < r(B), the first components of tuples from 
C change its values no more than 2 r(B) + 1 times. Denote by C\ subsequence of C' that 
includes all the tuples from C' with first component equals zero and by C' 2 that includes all 
the tuples from C' with first component equals one. Both sequences C[ and C' 2 are chains 
of n + 1-tuples. 

By the inductive assumption inequalities 

d C '(G) < d(G) < (2 r(B) + 1) (2 /s(G) - l) = (2 r(B) + 1) (2 /s(F) ' 1 - l) 
hold, i = 1,2. Using equations 

fii,X l, • • • , X n ) (]j {h(xi, . . . , X n ), X ±, . . . , X n ) , % 1, . . . , Tft, 

we obtain 


d c (F) < d C '(G) + d C '(G) + 2 r(B) + 1 < 

< (2 r(B) + 1) (2(2 /s(g) - 1) + 1) < (2 r(B) + 1) ( 2 Ib(f) - l) . 


Thus, Lemma 1 is proved. 

Let c(B) = log 2 (2 r(B) + 1) + 1. 


□ 


O 



Lemma 2. Let F C P^- Then 


Ib(F)> \\og 2 (d(F) + l)]-c(B). 


Proof. Lemma 1 implies estimation 


2 i b(f) > 


2r(R) + 1 


Hence, 


/ b (F) > log 2 


f g) 


+ 1 > lOg; 


d(F) + 1 

2 2 r(B) + 1 


> 


\2r(B) + 1 

> log 2 (d(F) + 1) - log 2 (2r(5) + 1) > 

> Rog 2 (d(F) + 1)1 - (log 2 (2r(H) + 1) + 1) = 

= riog 2 (d(F) + l)l~c(B). 


Lemma 2 is proved. 

□ 

Lemma 2 completes the proof of the Theorem. 

Remark. The result of Lemma 1 is rather rough. More accurately reasoning decreases value 
of c(B) in the Theorem. 
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